package com.atguigu.gulimall.ware.dao;

import com.atguigu.gulimall.ware.entity.WareSkuEntity;
import com.baomidou.mybatisplus.core.mapper.BaseMapper;
import org.apache.ibatis.annotations.Mapper;
import org.apache.ibatis.annotations.Param;

import java.util.List;

/**
 * 商品库存
 * 
 * @author lk
 * @email lk@gmail.com
 * @date 2023-12-17 21:26:56
 */
@Mapper
public interface WareSkuDao extends BaseMapper<WareSkuEntity> {

    void addStock(@Param("skuId") Long skuId, @Param("wareId")Long wareId, @Param("skuNum")Integer skuNum);

    Long getSkuStock(Long skuId);

    /**
     * 查询这个商品在哪个仓库有库存
     * @param skuId skuId
     * @return 仓库编号
     */
    List<Long> listWareIdHasSkuStock(@Param("skuId")Long skuId);

    /**
     * 锁定库存
     * @param skuId 商品编号
     * @param wareId 库存编号
     * @param num 购买商品数量
     * @return Long
     */
    Long lockSkuStock(@Param("skuId") Long skuId, @Param("wareId") Long wareId, @Param("num") Integer num);
}
